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METHOD AND APPARATUS FOR SHORTENING THE CRITICAL PATH OF 
REDUCED COMPLEXITY SEQUENCE ESTIMATION TECHNIQUES 

Field of the Invention 

The present invention relates generally to channel equalization and decoding 
techniques, and more particularly, to sequence estimation techniques with shorter critical paths. 



Background of the Invention 

The transmission rates for local area networks (LANs) that use twisted pair 
10 conductors have progressively increased from 10 Megabits-per-second (Mbps) to 1 Gigabit-per- 
second (Gbps). The Gigabit Ethernet 1000 Base-T standard, for example, operates at a clock rate 
of 125 MHz and uses category 5 cabling with four copper pairs to transmit 1 Gbps. Trellis-coded 
modulation (TCM) is employed by the transmitter, in a known manner, to achieve coding gain. 
The signals arriving at the receiver are typically corrupted by intersymbol interference (ISI), 
15 crosstalk, echo, and noise. A major challenge for 1000 Base-T receivers is to jointly equalize the 
channel and decode the corrupted trellis-coded signals at the demanded clock rate of 125 MHz, 
as the algorithms for joint equalization and decoding incorporate non-linear feedback loops that 
cannot be pipelined. 

Data detection is often performed using maximum likelihood sequence estimation 
20 (MLSE), to produce the output symbols or bits. A maximum likelihood sequence estimator 
(MLSE) considers all possible sequences and determines which sequence was actually 
transmitted, in a known manner. The maximum likelihood sequence estimator (MLSE) is the 
optimum decoder and applies the well-known Viterbi algorithm to perform joint equalization and 
decoding. For a more detailed discussion of a Viterbi implementation of a maximum likelihood 
25 sequence estimator (MLSE), see Gerhard Fettweis and Heinrich Meyr, "High-Speed Parallel 
Viterbi Decoding Algorithm and VLSI-Architecture," IEEE Communication Magazine (May 
1991), incorporated by reference herein. 

In order to reduce the hardware complexity for the maximum likelihood sequence 
estimator (MLSE) that applies the Viterbi algorithm, a number of sub-optimal approaches, such 
30 as "reduced state sequence estimation (RSSE)" algorithms, have been proposed or suggested. 
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For a discussion of reduced state sequence estimation (RSSE) techniques, as well as the special 
cases of decision-feedback sequence estimation (DFSE) and parallel decision-feedback 
equalization (PDFE) techniques, see, for example, P. R. Chevillat and E. Eleftheriou, "Decoding 
of Trellis-Encoded Signals in the Presence of Intersymbol Interference and Noise", IEEE Trans. 

5 Commun, vol. 37, 669-76, (July 1989), M. V. Eyuboglu and S. U. H. Qureshi, "Reduced-State 
Sequence Estimation For Coded Modulation On Intersymbol Interference Channels", IEEE 
JSAC, vol. 7, 989-95 (Aug. 1989), or A. Duel-Hallen and C. Heegard, "Delayed decision- 
feedback sequence estimation," IEEE Trans. Commun., vol. 37, pp. 428-436, May 1989, each 
incorporated by reference herein. For a discussion of the M algorithm, see, for example, E. F. 

10 Haratsch, "High-Speed VLSI Implementation of Reduced Complexity Sequence Estimation 
Algorithms With Application to Gigabit Ethernet 1000 Base-T," Int'l Symposium on VLSI 
Technology, Systems, and Applications, Taipei (Jun. 1999), incorporated by reference herein. 

Generally, reduced state sequence estimation (RSSE) techniques reduce the 
complexity of the maximum likelihood sequence estimators (MLSE) by merging several states. 

15 The RSSE technique incorporates non-linear feedback loops that cannot be pipelined. The 
critical path associated with these feedback loops is the limiting factor for high-speed 
implementations. 

United States Patent Application Serial Number 09/326,785, filed June 4, 1999 
and entitled "Method and Apparatus for Reducing the Computational Complexity and Relaxing 

20 the Critical Path of Reduced State Sequence Estimation (RSSE) Techniques," incorporated by 
reference herein, discloses a reduced state sequence estimation (RSSE) algorithm that reduces the 
hardware complexity of RSSE techniques for a given number of states and also relaxes the 
critical path problem. While the disclosed RSSE algorithm exhibits significantly improved 
processing time, additional processing gains are needed for many high-speed applications. A 

25 need therefore exists for a reduced state sequence estimation (RSSE) algorithm with improved 
processing time. Yet another need exists for a reduced state sequence estimation (RSSE) 
algorithm that is better suited for a high-speed implementation using very large scale integration 
(VLSI) techniques. 



-2- 



Azadet 10-2 



Summary of the Invention 

Generally, a method and apparatus are disclosed for improving the processing 
time of the reduced complexity sequence estimation techniques, such as the RSSE technique, for 
a given number of states. According to one feature of the invention, the possible values for the 

5 branch metrics in the reduced state sequence estimation (RSSE) technique are precomputed in a 
look-ahead fashion to permit pipelining and the shortening of the critical path. Thus, the present 
invention provides a delay that is similar to a traditional optimum Viterbi decoder. 
Precomputing the branch metrics for all possible symbol combinations in the channel memory in 
accordance with the present invention makes it possible to remove the branch metrics unit 

10 (BMU) and decision-feedback unit (DFU) from the feedback loop, thereby reducing the critical 
path. In the illustrative implementation, the functions of the branch metrics unit (BMU) and 
decision- feedback unit (DFU) are performed by a look-ahead branch metrics unit (LABMU) and 
an intersymbol interference canceller (ISIC) that are removed from the critical path, 

A reduced state sequence estimator (RSSE) is disclosed that provides a look- 

15 ahead branch metrics unit (LABMU) to precompute the branch metrics for all possible values for 
the channel memory. At the beginning of each decoding cycle, a set of multiplexers (MUXs) 
select the appropriate branch metrics based on the survivor symbols in the corresponding 
survivor path cells (SPCs), which are then sent to an add-compare-select unit (ACSU). The 
critical path now comprises one MUX, ACSC and SPC. The disclosed RSSE can be utilized for 

20 both one-dimensional and multi-dimensional trellis codes. 

For multi-dimensional trellis codes where the precomputation of multi- 
dimensional branch metrics becomes computationaly too expensive, a modified RSSE is 
disclosed to reduce the computational load. The metrics for each dimension of the multi- 
dimensional trellis code are precomputed separately. The appropriate one-dimensional branch 

25 metrics are then selected based on the corresponding survivor symbols in the corresponding 
survivor path cell (SPC) for that dimension. A multi-dimensional branch metrics unit then 
combines the selected one-dimensional branch metrics to form the multi-dimensional branch 
metrics. According to another aspect of the invention, prefiltering techniques are used to reduce 
the computational complexity by shortening the channel memory. An example is provided of a 
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specific implementation for a 1000 Base-T Gigabit Ethernet implementation that truncates the 
postcursor channel memory length to one. 

A novel memory-partitioned survivor memory architecture for the survivor 
memory units in the survivor path cell is also disclosed. In order to prevent latency for the 

5 storage of the survivor symbols, which are required in the decision feedback unit (DFU) or the 
multiplexer unit (MUXU) with zero latency, a hybrid survivor memory arrangement is disclosed 
for reduced state sequence estimation (RSSE). In an RSSE implementation for a channel memory 
of length Z, the survivor symbols corresponding to the L past decoding cycles are utilized (i) for 
intersymbol interference cancellation in the decision-feedback units (DFU) of a conventional 

10 RSSE, and (ii) for the selection of branch metrics in the multiplexers (MUXU) in an RSSE 
according to the present invention. The present invention stores the survivors corresponding to 
the X past decoding cycles in a register exchange architecture (REA), and survivors 
corresponding to later decoding cycles are stored in a trace-back architecture (TBA) or register 
exchange architecture (REA). Before symbols are moved from the register exchange architecture 

15 (REA) to the trace-back architecture (TBA), they are mapped to information bits to reduce the 
word size. In a 1000 Base-T implementation, the register exchange architecture (REA) is used 
for the entire survivor memory, as the latency introduced by the trace-back architecture (TBA) in 
the second memory partition would lead to a violation of the tight latency budget specified for 
the receiver in the 1000 Base-T standard. 

20 

Brief Description of the Drawings 

FIG. 1 illustrates an equivalent discrete time model of a conventional trellis coded 
communications system; 

FIG. 2 illustrates a conventional implementation of the Viterbi algorithm; 
25 FIG. 3 illustrates the architecture for conventional implementation of an reduced 

state sequence estimator (RSSE); 

FIG. 4 illustrates the architecture of a reduced state sequence estimator (RSSE) 
with precomputation of branch metrics in accordance with the present invention; 
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FIG. 5 illustrates the use of multi-dimensional trellis coded modulation for a 
multidimensional channel; 

FIG. 6 illustrates the architecture for a one-dimensional precomputation for a 
multi-dimensional reduced state sequence estimator (RSSE) in accordance with the present 
5 invention; 

FIG. 7 illustrates the architecture of a reduced state sequence estimator (RSSE) 
that utilizes prefiltering techniques in accordance with the present invention to shorten the 
channel memory; 

FIG. 8 illustrates a decision-feedback prefilter for a 1000 Base-T Gigabit Ethernet 
10 implementation that truncates the postcursor channel memory length from fourteen to one; 

FIG. 9 illustrates the look-ahead computation of ID branch metrics by one of the 
1D-LABMU units of FIG. 6 for the 1000 Base-T Gigabit Ethernet implementation; 

FIG. 10 illustrates the selection of the ID branch metrics by the multiplexer of 
FIG. 6 for the 1000 Base-T Gigabit Ethernet implementation; and 
15 FIG. 1 1 illustrates a novel memory-partitioned register exchange network (SPC-n) 

for state one for the 1000 Base-T Gigabit Ethernet implementation. 



Detailed Description 

As previously indicated, the processing speed for reduced complexity sequence 
20 estimation techniques, such as reduced state sequence estimation (RSSE), is limited by a 
recursive feedback loop. According to one feature of the present invention, the processing speed 
for such reduced state sequence estimation (RSSE) techniques is improved by precomputing the 
branch metrics in a look-ahead fashion. The precomputation of the branch metrics shortens the 
critical path, such that the delay is of the same order as in a traditional Viterbi decoder. 
25 According to another feature of the present invention, the computational load of the 
precomputations is significantly reduced for multi-dimensional trellis codes. Prefiltering can 
reduce the computational complexity by shortening the channel memory. The RSSE techniques 
of the present invention allow the implementation of RSSE for high-speed communications 
systems, such as the Gigabit Ethernet 1000 Base-T standard. 
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TRELLIS-CODED MODULATION 
As previously indicated, RSSE techniques reduce the computational complexity 
of the Viterbi algorithm, when the RSSE techniques are used to equalize uncoded signals or 
jointly decode and equalize signals, which have been coded, using trellis-coded modulation 

5 (TCM). While the present invention is illustrated herein using decoding and equalization of 
trellis coded signals, the present invention also applies to the equalization of uncoded signals, as 
would be apparent to a person of ordinary skill in the art. TCM is a combined coding and 
modulation scheme for band-limited channels. For a more detailed discussion of TCM, see, for 
example, G. Ungerboeck, "Trellis-Coded Modulation With Redundant Signal Sets," IEEE 

10 Comm., Vol. 25, No. 2, 5-21 (Feb. 1987), incorporated by reference herein. FIG. 1 illustrates the 
equivalent discrete time model of a trellis coded communications system. 

As shown in FIG. 1, information symbols x n consisting of m bits are fed into a 
TCM encoder 110. The rate m7<y+i) encoder 110 operates on m' input bits and produces 
w'+i encoded bits, which are used to select one of the 2 W ' +1 subsets (each of size 2 m ~ m ') from the 

15 employed signal constellation of size 2 m+1 , while the uncoded bits are used to select one symbol 
a n within the chosen subset. In the illustrative implementation, Z -level pulse amplitude 
modulation (Z -PAM) is used as the modulation scheme for the symbols a n . The techniques of 
the present invention, however, can be applied to other modulation schemes such as PSK or 
QAM, as would be apparent to a person of ordinary skill in the art. The selected symbol a n is 

20 sent over the equivalent discrete-time channel. Assuming a one-dimensional channel, the 
channel output z n at time instant n is given by: 

L 

Z n=<? n +Wn= Y<fi* a n-i + W n , (1) 
1=0 

where q n is the signal corrupted by ISI, {/;■}, ie[o,..,i] are the coefficients of the equivalent 
discrete-time channel impulse response (/ 0 = i is assumed without loss of generality), l is the 
25 length of the channel memory, and {w n } represents white Gaussian noise with zero mean and 
variance <? 2 . 
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The concatenation of the trellis coder and channel defines a combined code and 
channel state, which is given by 

=(f^ (2) 
where \i n is the code state and a n ={a n - L9 ... 9 a„_ x ) is the channel state at time n . The 
5 optimum decoder for the received signal is the maximum likelihood sequence estimator (MLSE) 
that applies the Viterbi algorithm to the super trellis defined by the combined code and channel 
state. The computation and storage requirements of the Viterbi algorithm are proportional to the 
number of states. The number of states of the super trellis is given by: 

T = Sx2 mL , (3) 
10 where s is the number of code states. 

The Viterbi algorithm searches for the most likely data sequence by efficiently 
accumulating the path metrics for all states. The branch metric for a transition from state 5„ 
under input a n is given by: 

~ a n -Htlfi a n~i] ' ( 4 ) 

15 Among all paths entering state £ B+1 from predecessor states the most likely 

path is chosen according to the following path metric calculation, which is commonly referred to 
as add-compare-select (ACS) calculation: 

rfe w+1 )= min (r(U^(z w ,^J). (5) 

An implementation of the Viterbi algorithm is shown in FIG. 2. The Viterbi 
20 implementation 200 shown in FIG. 2 comprises of a main components branch metric unit (BMU) 
210, an add-compare-select unit (ACSU) 220 and a survivor memory unit (SMU) 230. The 
branch metric unit (BMU) 210 calculates the metrics for the state transitions according to 
equation (4). The ACS unit (ACSU) 220 evaluates equation (5) for each state, and the survivor 
memory unit (SMU) 230 keeps track of the surviving paths. The data flow in the BMU 210 and 
25 SMU 230 is strictly feed-forward and can be pipelined at any level to increase throughput. The 
bottleneck for high-speed processing is the ACSU 220, as the recursion in the ACS operation in 
equation (5) demands that a decision is made before the next step of the trellis is decoded. 
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RSSE techniques reduce the complexity of the maximum likelihood sequence 
estimator (MLSE) by truncating the channel memory such that only the first K of the L channel 
coefficients {/;■}, fe[wj, are taken into account for the trellis. See, A. Duel-Hallen and C. 
Heegard, "Delayed decision-feedback sequence estimation/' IEEE Trans. Commun., vol. 37, pp. 

5 428-436, May 1989, incorporated by reference herein. In addition, the set partitioning principles 
described in P. R. Chevillat and E. Eleftheriou, "Decoding of Trellis-Encoded Signals in the 
Presence of Intersymbol Interference and Noise," IEEE Trans. Comm., Vol 37, 669-676 (Jul 
1989) and M.V. Eyubogiu and S. U. Qureshi, "Reduced-State Sequence Estimation for Coded 
Modulation on Intersymbol Interference Channels " IEEE JSAC, Vol. 7, 989-995 (Aug. 1989), 

10 each incorporated by reference herein, are applied to the signal alphabet. The reduced combined 
channel and code state is given in RSSE by 

where j n _ ( is the subset the data symbol a nA belongs to. The number of different subsets j nA is 
given by 2 m > , where m i defines the depth of subset partitioning at time instant n-i . It is required 
15 that 

m'< m K < rn K _ l < ... < m x < m . (7) 

The number of states in the reduced super trellis is given as follows: 
i? = Sx2 Wjc+ " +Ml . (8) 

In RSSE, the branch metric for reduced state p„ under input a n takes the 

20 modified form: 

K ( z n > a n > Pn )= i?n ~ a n+ u n (p» F ? ( 9 ) 

where: 

a«(pJ=fe-i(p«V ^«-i(p«)) is the survivor sequence leading to the reduced state p„ and 
25 a B -,-(p n ) is the associated survivor symbol at time instant n-i . In equation (10), an ISI estimate 
«(p„) is calculated for state p n by taking the data symbols associated with the path history of 
state p re as tentative decisions. The best path metric for state p w+l is obtained by evaluating 
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r (p«+i)= f F n ( r (p») + ^«( z »^«>P«))* (11) 

RSSE can be viewed as a sub-optimum trellis decoding algorithm where each 
state uses decision-feedback from its own survivor path to account for the ISI not considered in 
5 the reduced trellis. 

FIG. 3 illustrates the architecture for the implementation of RSSE. As shown in 
FIG. 3, the decision-feedback cells (DFC) in the decision-feedback unit (DFU) 340 calculate R 
ISI estimates by considering the survivors in the corresponding survivor path cell (SPC) of the 
SMU 330 according to equation (10). Each branch metric cell (BMC) in the BMU 310 computes 

10 the metrics for the b = 2 m ' transitions leaving one state. For each state, the best path selection is 
performed in the ACS cell (ACSC) according to equation (11). In contrast to Viterbi decoding, 
the DFC, BMC, and SPC cells are in the critical loop in addition to the ACSC cell. The 
techniques for parallel processing of the Viterbi algorithm exploit the fact that the branch metric 
computation in equation (4) does not depend on the decision of the ACS function in equation (5). 

15 Thus, branch metrics can be calculated for k trellis steps in a look-ahead fashion to obtain a k - 
fold increase of the throughput. Sees G. Fettweis and H. Meyr, "High-Speed Viterbi Processor: 
A Systolic Array Solution," IEEE JSAC, Vol. 8, 1520-1534 (Oct. 1990) or United States Patent 
Number 5,042,036, incorporated by reference herein. However, for RSSE techniques, the branch 
metric computation in equation (9) depends on the decision of the ACSC in the ACSU 320, 

20 which evaluates equation (11), in the previous symbol period, as the surviving symbols in the 
SPC of the SMU 330 are needed for the decision-feedback computations in equation (10). Thus, 
the block processing techniques described in G. Fettweis and H. Meyr, referenced above, cannot 
be applied to speed up the processing of RSSE. 

PRECOMPUTATION OF BRANCH METRICS 

25 The critical path in RSSE involves more operations than in the Viterbi algorithm. 

In particular, the branch metric computations in the BMC can be very expensive in terms of 
processing time, as euclidean distances have to be obtained by either squaring or performing a 
table-lookup to achieve good coding gain performance. Also, the evaluation of equation (10) in 
the DFC 340-n may have a significant contribution to the critical path. Precomputing all branch 
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metrics for all possible symbol combinations in the channel memory in accordance with the 
present invention makes it possible to remove the BMU 310 and DFU 340 from the feedback 
loop. This potentially allows for a significant reduction of the critical path in RSSE. 

In principle, the channel state a B =(fl„. iv ,vi) can take u = different values. 
5 The ISI estimates for a particular channel assignment a=(a n _ L> .,,a„_ l ) can be obtained by 
evaluating the following equation: 

"(a)— Hiffi^ . (12) 

It is noted that equation (12) does not depend on the time n and is thus a constant 
for a particular channel assignment a . The speculative branch metric for a transition from 
10 channel assignment a under input a n is then given by 

X n (z n ,a n ,a)=(z n ~a n +u(S)f . (13) 

The trellis coder 100 in FIG. 1 defines 2b = i m ' +l different subsets. Assuming that 
in the case of parallel transitions the best representative in a subset is obtained by slicing, a 
maximum of M = 2bxU = 2 m ' +l x i( m+x ) L different branch metrics \ n (z n , a n ,d) are possible and have to 

15 be precomputed. The trellis coder shown in FIG. 1 may not allow all symbol combinations in the 
channel memory a n . Therefore, the number of branch metrics which have to be precomputed 
might be less than M. The actual number of branch metrics which have to be precomputed should 
be determined from the reduced super trellis. 

For the add-compare-select cell (ACSC) 320-n, the appropriate branch metrics 

20 x n (z n , a n , p n ) among all precomputed branch metrics x n (z n , a„ ,6r) are selected by using the survivor 
path d„( Pw ): 

K { z n > a n » P n ) = ^ e/ { A « i Z n^n > Pn \<* n (p« )} * (14) 

In equation (14), A n (z n ,a n ,p n ) is a vector containing the 2 mL branch 
metrics x n (z n9 a n9 S) 9 which can occur for a transition from state p„ under input a n for different 

25 channel assignments a . The selector function in equation (14) can be implemented with a 2 mL to 
1 multiplexer. 

It is noted that equations (12) and (13) are both independent from the decision in 
the recursive ACS function in equation (11). Thus, the precomputations in equations (12) and 
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(13) are strictly feed- forward and can be pipelined at any level. Only the selection function in 
equation (14) lies in the critical path in addition to the add-compare-select cell (ACSC) and 
survivor path cell (SPC). 

The architecture of an RSSE 400 with precomputation of branch metrics in 

5 accordance with the present invention is shown in FIG. 4. The ISI canceller (ISIC) 420 
calculates all U values which can occur for w(a). Each of these U values is used by a 
corresponding look-ahead BMC (LABMC) 410-n to calculate 2b speculative branch metrics 
x n (z n ,a n ,a) . All the M = 2bu branch metrics precomputed in the look-ahead BMU (LABMU) 
410 are then sent to the MUX unit (MUXU) 430. Then, at the beginning of each decoding cycle, 

10 each multiplexer (MUX) 430-n in the MUX unit (MUXU) 430 selects the appropriate branch 
metrics based on the survivor symbols in the corresponding SPC 450-n, which are then sent to 
the ACSU 440. Each multiplexer (MUX) 430-n in the MUX unit (MUXU) 430 takes L past 
symbols from the corresponding survivor path cell (SPC) 450-n. The ACSU 440 and SMU 450 
may be embodied as in the conventional RSSE 300 of FIG. 3. The output of the LABMU 410 is 

15 placed in a pipeline register 460. The critical path now comprises of just the MUX 430, ACSC 
440-n, and SPC 450-n. The MUX 430 selects a branch metric in accordance with equation (14) 
dependent on the symbols in the SPC 450-n. Although the number of precomputed branch 
metrics increases exponentially with the channel memory L and the number of information bits 
m , this technique is feasible for small m (corresponding to small symbol constellation sizes) and 

20 short L . 

PRECOMPUTATION FOR MULTIDIMENSIONAL TRELLIS CODES 

Significant coding gains for large signal constellations can be achieved with 
multidimensional TCM. FIG. 5 illustrates the use of multi-dimensional trellis coded modulation 
for a multidimensional channel. The B -dimensional symbol a n = {a n ^.^a n B ), where a n is a 
25 vector, is sent over the B -dimensional channel with the channel coefficients {f u , /e[o,..,i], 
j e such that the channel output z n = (z n il9 ..,z R B ), is a vector given as 

z nJ = HfiJ' a n-iJ + w nJ , J ^K^], (15) 

/=0 
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where {w nJ } 9 j e [l,..,5] are B uncorrelated independent white Gaussian noise sources. Z-PAM 
is considered as the transmission scheme for each channel. The following results are valid for 
other modulation schemes as well. Such an equivalent discrete time channel can be found for 
example in Gigabit Ethernet 1 000 Base-T over copper, where 5 = 4 ? m = 8 ? m' = 2,5 f = 8 > Z = 5. See 
5 K. Azadet, "Gigabit Ethernet Over Unshielded Twisted Pair Cables," Intl Symposium on VLSI 
Technology, Systems, and Applications, Taipei (Jun. 1999), incorporated by reference herein. 

As the complexity for the precomputation of branch metrics grows exponentially 
with the number of information bits m , there might be cases where the precomputation of multi- 
dimensional branch metrics as shown in FIG. 4 might be too computationally expensive for 
10 large signal constellation sizes. However, performing precomputations of the branch metrics only 
for the one-dimensional components of the code can significantly reduce the complexity. 

The 1 -dimensional branch metric in the dimension j is precomputed by 
evaluating the following expressions: 

15 Uj{$j)—Y.lifijan-ij , (17) 

where dj = {a n _ L j ^a n _ X j ) is a particular assignment for the channel state aj = (a n _ LJ ,..,a n ^j) in 
dimension j. 

There are v = z L possible 1 -dimensional channel assignments a,-. For a given 
channel assignment & j9 c inputs a nJ have to be considered to calculate all possible 1- 

20 dimensional branch metrics X n j {z n j ,a n jy a J \ where c, C <Z is the number of 1 -dimensional 

subsets. Each of these C inputs a n j corresponds to the point in the corresponding subset to which 

{z nJ ) has been sliced to after the cancellation of the intersymbol interference according to 

equations (16) and (17). Consequently, considering all B dimensions, a total N = BxCxV 1- 
dimensional branch metrics have to be precomputed. This can be considerably less than the 
25 number of precomputations necessary for multidimensional precomputations as discussed above 
in the section entitled "Precomputation of Branch Metrics." In the case of the Gigabit Ethernet 
1000 Base-T, with c = 2 z = i, and Z = 5 1- dimensional precomputation yields a total of 
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4x2x5 = 40 1 -dimensional branch metric computations, whereas multi-dimensional 
precomputation results in 2 3 x 2 9 = 4096 4-dimensional branch metric computations. 

The selection of the appropriate 1 -dimensional branch metrics for further 
processing in RSSE is given by: 

5 Kj i Z nJ > a n,j > P n)= sel { K nJ { z nJ > a nJ \<*n,j (p « )} (18) 

where A nJ (z nJ ,a nJ ) is the vector containing all v possible 1-dimensional branch metrics 

Kj{ z nj> a nj&j) under input a nj for different one-dimensional channel assignments a y . and 

& n j{p n ) is the survivor sequence in dimension j leading to state p B . This can be implemented 

using a v to 1 MUX compared to the 2 mL to 1 MUX needed for multi-dimensional 
10 precomputation (e.g., in the 1000 Base-T example above, 5 to 1 MUXs are required c.f. to 256 to 
1 MUXs). After the appropriate ID branch metrics have been selected, the multidimensional 
branch metric is given as 

K( z n>*n>Pn)= Kj { z n,j > a nJ > P n ) (19). 

FIG. 6 illustrates the architecture 600 for 1-dimensional precomputation for multi- 
15 dimensional RSSE. Each 1D-ISIC 620-n calculates the FISI cancellation terms uj(aj). For 
each of these Uj(Sj), the corresponding 1D-LABMC 610-n precomputes C one-dimensional 
branch metrics per channel assignment and dimension in the 1D-LABMU 610. The MUXU 630 
selects for each state the appropriate one-dimensional branch metrics dependent on the survivor 
symbols in the SPC 660-n. Each multi-dimensional BMC (MD-BMC) 640-n calculates the 
20 multi-dimensional branch metrics by using the selected 1-dimensional branch metrics. The 
critical path now comprises one MUX 630, MD-BMC 640, ACSC 650 and SPC 660. The MD- 
BMC 640 performs B-\ additions and consequently has a minor contribution to the overall 
critical path, as the number of dimensions B is typically low. 

PREFILTERING 

25 It has been shown that the complexity for the precomputation of branch metrics 

increases exponentially with the channel memory L. However, using the prefilter 710, shown in 
FIG. 7, can shorten the channel memory. As the equivalent discrete time channel after a 
whitened matched filter is minimum-phase, the channel memory can be truncated with a decision 
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feedback prefilter (DFP) to low values of L without significant performance loss for RSSE, as 
described in E. F. Haratsch, "High-Speed VLSI Implementation of Reduced Complexity 
Sequence Estimation Algorithms With Application to Gigabit Ethernet 1000 Base-T ," Int'l 
Symposium on VLSI Technology, Systems, and Applications, Taipei (Jun. 1999) and United 
5 States Patent Application Serial Number 09/326,785, filed June 4, 1999 and entitled "Method 
and Apparatus for Reducing the Computational Complexity and Relaxing the Critical Path of 
Reduced State Sequence Estimation (RSSE) Techniques," each incorporated by reference herein. 
Alternatively, the prefilter 710 could be implemented as a linear filter, such as those described in 
D.D. Falconer and F.R. Magee, "Adaptive Channel Memory Truncation for Maximum- 

10 Likelihood Sequence Estimation," The Bell Systems Technical Journal, Vol. 52, No. 9, 1541-62 
(Nov. 1973), incorporated by reference herein. 

Thus, for channels with large channel memories where the precomputation of 
branch metrics is too expensive, a prefilter could be used to truncate the channel memory such 
that precomputation becomes feasible. 

15 1000-BASE T GIGABIT ETHERNET EXAMPLE 

The following is an example of a specific implementation for a 1000 Base-T 
Gigabit Ethernet receiver. For a detailed discussion of the 1000 Base-T Gigabit Ethernet 
standard and related terminology and computations used herein, see, for example, M. Hatamian 
et al., "Design considerations for Gigabit Ethernet 1000 Base-T twisted pair transceivers," Proc. 

20 CICC, Santa Clara, CA, pp. 335-342, May 1998, incorporated by reference herein. 

A decision-feedback prefilter for the 1000 Base-T Gigabit Ethernet 
implementation is shown in FIG. 8. The look-ahead computation of ID branch metrics by one of 
the 1D-LABMU units of FIG. 6 for the 1000 Base-T Gigabit Ethernet implementation is shown 
in FIG. 9. FIG. 10 illustrates the selection of the ID branch metrics by the multiplexer of FIG. 6 

25 for the 1000 Base-T Gigabit Ethernet implementation. Finally, FIG. 11 illustrates the register 
exchange network (SPC n) for state one for the 1000 Base-T Gigabit Ethernet implementation, 
where an illustrative merge depth of 14 is utilized for the SMU. 
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Decision-Feedback Prefilter 



A decision-feedback prefilter 800 that truncates the postcursor memory length on 



wire pair j from fourteen to one is shown in FIG. 8. The decision-feedback prefilter 800 
resembles the structure of a decision-feedback equalizer (DFE) as it uses tentative decisions 
5 obtained by its own sheer to remove the tail of the postcursor channel impulse response. 
Precomputation of ID branch metrics 

As the effective postcursor channel memory is one after the decision-feedback 
prefilter 800, the computational complexity for look-ahead precomputations of ID branch 
metrics on each wire pair is modest. The speculative ID branch metric for wire pair j under the 
10 assumption that the channel memory contains a n _ X j is 



As there are 5 possible values for a nJ , and as y n j after removal of intersymbol interference has 

to be sliced to the closest representative of both ID subsets A as well as B, & total of 10 ID 
branch metrics have to be precompiled per wire pair. This is shown in FIG. 9, where the slicers 

15 910-n calculate the difference to the closest point in ID subset A or B. There is one clock cycle 
time for one addition, slicing, and squaring. It should be noted that the computational complexity 
of precompiling branch metrics increases exponentially with the channel memory. If the channel 
memory were two, 50 ID branch metrics would have to be precomputed per wire pair, and for a 
channel memory of three this number would increase to 250. 

20 Selection of ID Branch Metrics 

The MUXU 630 selects for each wire pair j and code state p n the appropriate ID 
branch metrics corresponding to subsets A and B based on the past survivor symbol a n _ i j{p n ) . 
This is done with 5:1 MUXs 1010 as shown in FIG. 10. In total, 64 such multiplexers are needed. 



metrics corresponding to state transitions in the trellis. The 4D-BMU 640 is in the critical loop. 
Bringing the 4D-BMU 640 out of the critical loop by look-ahead precomputations of 4D branch 
metrics would be impractical in terms of computational complexity, as shown in the example 




(20) 



25 



Computation of 4D Branch Metrics 

The 4D-BMU 640 adds up the ID branch metrics to calculate the 4D branch 
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discussed above in the section entitled "Precomputation of Multi-Dimensional Trellis Codes." It 
can be easily seen that there are too many possibilities, which must be considered. 
Add-Compare- S elect 

For each state, a 4-way ACS has to be performed. To speed up the processing, the 
5 architecture proposed in PJ. Black and T.H. Meng, "A 140-Mb/s, 32-state, radix-4 Viterbi 
decoder," IEEE JSSC, vol. 27, pp. 1877-1885, Dec. 1992, has been chosen, where the minimum 
path metric among the 4 candidates is selected by 6 comparisons in parallel. State metric 
normalization is done using modulo arithmetic, See, A.P. Hekstra, "An Alternative To Metric 
Rescaling In Viterbi Decoders", IEEE Trans. Commun., vol. 37, pp. 1220-1222, Nov. 1989. 

1 0 Survivor Memory 

In Viterbi decoding, usually the trace-back architecture (TBA) is the preferred 
architecture for the survivor memory as it has considerably less power consumption than the 
register exchange architecture (REA). R. Cypher and C.B. Shung, "Generalized Trace-Back 
Techniques For Survivor Memory Management In The Viterbi Algorithm," Journal of VLSI 

15 Signal Processing, vol. 5, pp. 85-94, 1993. However, as the trace-back architecture (TBA) 
introduces latency it cannot be used to store the survivor symbols, which are required in the DFU 
or MUXU with zero latency. Thus, a hybrid survivor memory arrangement seems to be favorable 
for a reduced state sequence estimation (RSSE) implementation for a channel of memory length 
L. The survivors corresponding to the L past decoding cycles are stored in a register exchange 

20 architecture (REA), and survivors corresponding to later decoding cycles in a trace-back 
architecture (TBA). Before symbols are moved from the register exchange architecture (REA) to 
the trace-back architecture (TBA), they are mapped to information bits to reduce the word size. 
However, in 1000 Base-T the register exchange architecture (REA) must be used for the entire 
survivor memory, as the latency introduced by the trace-back architecture (TBA) would lead to a 

25 violation of the tight latency budget specified for the receiver in the 1000 Base-T standard. 
Likewise, symbols moved from the first register exchange architecture (REA) to the second 
register exchange architecture (REA) are mapped to information bits to reduce the word size. 

The survivor memory architecture is shown in FIG. 11, where only the first row 
corresponding to state one is shown. SX n (p n ) denotes the decision for 4D subset SXfor a. 
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transition from state p n (for definition of 4D subsets see, Hatamian et al.), 6 w _-(pJ are the 8 
information bits which correspond to the 4D survivor symbol a a _-(p n ) and d n (l) is the 2-bit 
decision of the ACS for state one. As the channel memory seen by the reduced state sequence 
estimation (RSSE) is one, only the first column stores 4D symbols, which are represented by 12 
5 bits and are fed into the MUXU. After this first column, the survivor symbols are mapped to 
information bits and then stored as 8 bits. For a merge depth of 14, this architecture needs 928 
REGs compared to 1344 REGs in an SMU which does not apply the hybrid memory partition, 
where all decisions are stored as 12 bit 4D symbols. 

It is to be understood that the embodiments and variations shown and described 
10 herein are merely illustrative of the principles of this invention and that various modifications 
may be implemented by those skilled in the art without departing from the scope and spirit of the 
invention. 

15 
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We claim: 

1 

1 LA method for processing a signal received from a dispersive channel using a 

2 reduced complexity sequence estimation technique, said channel having a channel memory, said 

3 method comprising the steps of: 

4 precomputing branch metrics for each possible value of said channel memory; 

5 selecting one of said precomputed branch metrics based on past decisions from 

6 corresponding states; and 

7 selecting a path having a best path metric for a given state. 

1 2. The method of claim 1, wherein said precomputed branch metrics for a 

2 transition from channel assignment s under input a n is given by: 

3 X n (z R> a ni a) = {z R -a n +u(a)f . 

4 where an intersymbol interference estimate for a particular channel assignment & = (? n -. L ,..,a„-i) 

5 can be obtained by evaluating the following equation: 

6 u{a)=-J d f =l f i a n _ i . 

1 3. The method of claim 1, wherein said path metric is an accumulation of 

2 said corresponding branch metrics over time. 

1 4. The method of claim 1 , wherein an appropriate branch metrics x n (z n , a n , p n ) 

2 is selected from said precomputed branch metrics x n (z n9 a„,S) using the survivor path d B (p„ ) : 

3 K i?n * a n > Pn ) = seI { A n { z n, a n > Pn )><*« (p« )} • 

4 where A n (z n ,a n ,p n ) is a vector containing the branch metrics x n (z n9 a Rt S) 9 which can occur for a 

5 transition from state p B under input a n for different channel assignments a and d B (p„) is the 

6 survivor sequence leading to state p n . 
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1 5. The method of claim 1, wherein said best path metric is a minimum or 

2 maximum path metric. 



1 6. The method of claim 1, wherein said reduced complexity sequence 

2 estimation technique is a reduced state sequence estimation (RSSE) technique. 

1 7. The method according to claim 6, wherein said reduced state sequence 

2 estimation (RSSE) technique is a decision-feedback sequence estimation (DFSE) technique. 

1 8. The method according to claim 6, wherein said reduced state sequence 

2 estimation (RSSE) technique is a parallel decision- feedback equalization (PDFE) technique. 

1 9. The method of claim 1, wherein said reduced complexity sequence 

2 estimation technique is an implementation of the Viterbi algorithm. 

1 10. The method of claim 1, wherein said reduced complexity sequence 

2 estimation technique is an implementation of the M algorithm. 



1 11. The method of claim 1, wherein said past decisions from corresponding 

2 states are based on past symbols from a corresponding survivor path cell (SPC). 



1 12. The method of claim 1, wherein said past decisions from corresponding 

2 states are based on past decisions from a corresponding add-compare-select cell (ACSC). 

1 13. A method for processing a multi-dimensional trellis code signal received 

2 from a dispersive channel using a reduced complexity sequence estimation technique, said 

3 channel having a channel memory, said method comprising the steps of: 

4 precomputing a one-dimensional branch metric for each possible value of said 

5 channel memory and for each dimension of the multi-dimensional trellis code; 
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6 selecting one of said precomputed one-dimensional branch metric based on past 

7 decisions from corresponding states; and 

8 combining said selected one-dimensional branch metrics to obtain a multi- 

9 dimensional branch metric. 
10 

1 14. The method of claim 13, wherein said one-dimensional branch metric in 



2 the dimension j is precomputed by evaluating the following expressions: 

3 Kj{ z nJ^nJ^j)={ z nJ ~ a nJ + )) 2 and U j l(lj)=-^ =1 f i ja n _ u , 

4 where a 7 - =(a„„ £Jv .,2'„_ lj ) is a particular assignment for the channel state oLj=(a n _ LJy ..,a n ^j) in 

5 dimension j. 



1 15. The method of claim 13, wherein said selection of an appropriate one- 

2 dimensional branch metrics for further processing with a reduced complexity sequence estimator 

3 is given by: 

4 Kj { z nJ > <*nj > P» )= sel { A nJ i Z nJ > a nJ \<*nj (p« )} 

5 where A nJ (z n j,a nJ ) is the vector containing possible one-dimensional branch metrics 

6 x n j(z nJ ,a nJ ,aj) under input a nj for different one-dimensional channel assignments a . and 

7 d„j(p B ) is the survivor sequence in dimension j leading to state p„ . 

1 16. The method of claim 13, wherein said past decisions from corresponding 

2 states are based on past symbols from a corresponding survivor path cell (SPC). 

1 17. The method of claim 13, wherein said past decisions from corresponding 

2 states are based on past decisions from a corresponding add-compare-select cell (ACSC). 

1 18. A method for processing a multi-dimensional trellis code signal received 

2 from a dispersive channel using a reduced complexity sequence estimation technique, said 

3 channel having a channel memory, said method comprising the steps of: 
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4 precomputing a one-dimensional branch metric for each possible value of said 

5 channel memory and for each dimension of the multi-dimensional trellis code; 

6 combining said one-dimensional branch metric into at least two-dimensional 

7 branch metrics; and 

8 selecting one of said at least two-dimensional branch metrics based on past 

9 decisions from corresponding states. 
10 

1 19. The method of claim 18, wherein said one-dimensional branch metric in 

2 the dimension j is precomputed by evaluating the following expressions: 

3 Kj{ z nJ> a n,j>$j)={ z n,j ~ a n,j + " y(<* ' « 'jfa j)= "Y^lfi^n-iJ > 

4 where &j ={a n - L j,--,a n _ lJ ) is a particular assignment for the channel state a, r=[a tt -Lj>-> a n-\,j) i* 1 

5 dimension j. 

1 20. The method of claim 18, wherein said selection of an appropriate at least 



2 two-dimensional branch metrics corresponding to a particular state and input for further 

3 processing with a reduced complexity sequence estimator is based on the survivor symbols for 

4 said state and said at least two dimensions and said selection is performed among all 

5 precomputed at least two-dimensional branch metrics for said state, input and different channel 

6 assignments for said dimensions. 



1 21. The method of claim 18, wherein said past decisions from corresponding 

2 states are based on past symbols from a corresponding survivor path cell (SPC). 

1 22. The method of claim 18, wherein said past decisions from corresponding 

2 states are based on past decisions from a corresponding add-compare-select cell (ACSC). 

1 23. The method of claim 18, further comprising the step of combining said 

2 selected at least two-dimensional branch metric to obtain a multi-dimensional branch metric. 
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1 24. A method for processing a signal received from a dispersive channel using 

2 a reduced complexity sequence estimation technique, said channel having a channel memory, 

3 said method comprising the steps of: 

4 prefiltering said signal to shorten said channel memory; 

5 precomputing branch metrics for each possible value of said shortened channel 

6 memory; 

7 selecting one of said precomputed branch metrics based on past decisions from 

8 corresponding states; and 

9 selecting a path having a best path metric for a given state. 
10 

1 25. The method of claim 24, wherein said prefiltering step further comprises 



2 the step of processing less significant taps with a lower complexity cancellation algorithm that 

3 cancels the less significant taps using tentative decisions and processing more significant taps 

4 with a reduced state sequence estimation (RSSE) technique. 

5 



1 26. The method according to claim 24, wherein said lower complexity 

2 cancellation algorithm is a decision feedback prefilter (DFP) technique. 

1 27, The method according to claim 24, wherein said lower complexity 

2 cancellation algorithm utilizes a linear equalizer technique. 

1 28. The method according to claim 24, wherein said lower complexity 

2 cancellation algorithm is a soft decision feedback prefilter (DFP) technique. 

1 29. The method according to claim 24, wherein said lower complexity 

2 cancellation algorithm reduces the intersymbol interference associated with said less significant 

3 taps. 
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1 30. The method according to claim 24, wherein said more significant taps 

2 comprise taps below a tap number, U, where U is a prescribed number less than L. 

1 31. The method according to claim 24, wherein said reduced complexity 

2 sequence estimation technique is a decision-feedback sequence estimation (DFSE) technique. 

1 32. The method according to claim 24, wherein said reduced complexity 

2 sequence estimation technique is a parallel decision-feedback equalization (PDFE) technique. 

1 33. The method according to claim 24, wherein said reduced complexity 

2 sequence estimation technique is a reduced state sequence estimation (RSSE) technique. 

1 34. The method according to claim 24, wherein said reduced complexity 

2 sequence estimation technique is an implementation of the Viterbi algorithm. 

1 35. The method according to claim 24, wherein said reduced complexity 

2 sequence estimation technique is an implementation of the M algorithm. 

1 36. The method of claim 24, wherein said past decisions from corresponding 

2 states are based on past symbols from a corresponding survivor path cell (SPC). 

1 37. The method of claim 24, wherein said past decisions from corresponding 

2 states are based on past decisions from a corresponding add-compare-select cell (ACSC). 

1 38. A method for processing a signal received from a dispersive channel using 

2 a reduced complexity sequence estimation technique, said channel having a channel memory, 

3 said method comprising the steps of: 

4 prefiltering said signal to shorten said channel memory; 
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5 precomputing a one-dimensional branch metric for each possible value of said 

6 shortened channel memory and for each dimension of the multi-dimensional trellis code; 

7 combining said one-dimensional branch metric into at least two-dimensional 

8 branch metrics; and 

9 selecting one of said at least two-dimensional branch metrics based on past 
10 decisions from corresponding states. 

1 39. A hybrid survivor memory architecture for a reduced complexity sequence 

2 estimator for a channel having a channel memory of length L, comprising: 

3 a register exchange architecture (REA) for storing the survivors corresponding to 

4 the L past decoding cycles; and 

5 a trace-back architecture (TBA) for storing survivors corresponding to later 

6 decoding cycles, wherein symbols moved from said register exchange architecture (REA) to said 

7 trace-back architecture (TBA) are mapped to information bits. 

1 40. The survivor memory architecture of claim 39, wherein said reduced 

2 complexity sequence estimation technique is a reduced state sequence estimation (RSSE) 

3 technique. 

1 41. The survivor memory architecture of claim 39, wherein said reduced 

2 complexity sequence estimation technique is an implementation of the Viterbi algorithm. 

1 42. The survivor memory architecture of claim 39, wherein said reduced 

2 complexity sequence estimation technique is an implementation of the M algorithm. 

1 43 . A hybrid survivor memory architecture for a reduced complexity sequence 

2 estimator for a channel having a channel memory of length L, comprising: 

3 a first register exchange architecture (REA) for storing the survivors 

4 corresponding to the L past decoding cycles; and 
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5 a second register exchange architecture (REA) for storing survivors corresponding 

6 to later decoding cycles, wherein symbols moved from said first register exchange architecture 

7 (REA) to said second register exchange architecture (REA) are mapped to information bits. 

1 44. The survivor memory architecture of claim 43 , wherein said reduced 

2 complexity sequence estimation technique is an reduced state sequence estimation (RSSE) 

3 technique. 

1 45. The survivor memory architecture of claim 43, wherein said reduced 

2 complexity sequence estimation technique is an implementation of the Viterbi algorithm. 

1 46. The survivor memory architecture of claim 43, wherein said reduced 

2 complexity sequence estimation technique is an implementation of the M algorithm. 

1 47. A reduced complexity sequence estimator for processing a signal received 

2 from a dispersive channel having a channel memory, comprising: 

3 a look-ahead branch metrics unit for precomputing branch metrics for each 

4 possible value of said channel memory; 

5 a multiplexer for selecting one of said precomputed branch metrics based on past 

6 decisions from corresponding states; and 

7 an add-compare-select unit for selecting a path having a best path metric for a 

8 given state. 

1 48. The reduced complexity sequence estimator of claim 47, wherein said past 

2 decisions from corresponding states are based on past symbols from a corresponding survivor 

3 path cell (SPC). 
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1 49. The reduced complexity sequence estimator of claim 47, wherein said past 

2 decisions from corresponding states are based on past decisions from a corresponding add- 

3 compare-select cell (ACSC). 

1 50. A reduced complexity sequence estimator for processing a signal received 

2 from a dispersive channel having a channel memory, comprising: 

3 a look-ahead branch metrics unit for precomputing a one-dimensional branch 

4 metric for each possible value of said channel memory and for each dimension of the multi- 

5 dimensional trellis code; 

6 a multiplexer for selecting one of said precomputed one-dimensional branch 

7 metric based on past decisions from corresponding states; and 

8 a multi-dimensional branch metric cell for combining said selected one- 

9 dimensional branch metrics to obtain a multi-dimensional branch metric. 
10 

1 51. The reduced complexity sequence estimator of claim 50, wherein said past 

2 decisions from corresponding states are based on past symbols from a corresponding survivor 

3 path cell (SPC). 

1 52. The reduced complexity sequence estimator of claim 50, wherein said past 

2 decisions from corresponding states are based on past decisions from a corresponding add- 

3 compare-select cell (ACSC). 

1 53. A reduced complexity sequence estimator for processing a signal received 

2 from a dispersive channel having a channel memory, comprising: 

3 a look-ahead branch metrics unit for precomputing a one-dimensional branch 

4 metric for each possible value of said channel memory and for each dimension of the multi- 

5 dimensional trellis code; 

6 means for combining said one-dimensional branch metric into at least two- 

7 dimensional branch metrics; 
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8 a multiplexer for selecting one of said at least two-dimensional branch metrics 

9 based on past decisions from corresponding states; and 

10 a multi-dimensional branch metric cell for combining said selected at least two- 

11 dimensional branch metric to obtain a multi-dimensional branch metric. 

1 54. The reduced complexity sequence estimator of claim 53, wherein said past 

2 decisions from corresponding states are based on past symbols from a corresponding survivor 

3 path cell (SPC). 

1 55. The reduced complexity sequence estimator of claim 53, wherein said past 

2 decisions from corresponding states are based on past decisions from a corresponding add- 

3 compare-select cell (ACSC). 

1 56. A reduced complexity sequence estimator for processing a signal received 

2 from a dispersive channel having a channel memory, comprising: 

3 a prefilter to shorten said channel memory; 

4 a look-ahead branch metrics unit for precomputing branch metrics for each 

5 possible value of said channel memory; 

6 a multiplexer for selecting one of said precomputed branch metrics based on past 

7 decisions from corresponding states; and 

8 an add-compare-select unit for selecting a path having a best path metric for a 

9 given state. 
10 

1 57. The reduced complexity sequence estimator of claim 56, wherein said past 

2 decisions from corresponding states are based on past symbols from a corresponding survivor 

3 path cell (SPC). 
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1 58. The reduced complexity sequence estimator of claim 56, wherein said past 

2 decisions from corresponding states are based on past decisions from a corresponding add- 

3 compare-select cell (ACSC). 

1 59. A reduced complexity sequence estimator for processing a signal received 

2 from a dispersive channel having a channel memory, comprising: 

3 a prefilter to shorten said channel memory; 

4 a multi-dimensional look-ahead branch metrics unit for precomputing a one- 

5 dimensional branch metric for each possible value of said shortened channel memory and for 

6 each dimension of the multi-dimensional trellis code; 

7 means for combining said one-dimensional branch metric into at least two- 

8 dimensional branch metrics; and 

9 a multiplexer for selecting one of said at least two-dimensional branch metrics 
10 based on past decisions from corresponding states. 
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ABSTRACT 

A method and apparatus are disclosed for improving the processing time of 
reduced complexity sequence estimation techniques, such as reduced state sequence estimation 

5 (RSSE). The possible values for the branch metrics in the RSSE are precomputed to permit 
pipelining and the shortening of the critical path. Precomputing the branch metrics for all 
possible symbol combinations in the channel memory makes it possible to remove the branch 
metrics unit (BMU) and decision-feedback unit (DFU) from the feedback loop, thereby reducing 
the critical path. A look-ahead branch metrics unit (LABMU) and an intersymbol interference 

10 canceller (ISIC) precompute the branch metrics for all possible values for the channel memory. 
At the beginning of each decoding cycle, a set of multiplexers (MUXs) select the appropriate 
branch metrics based on the survivor symbols in the corresponding survivor path cells (SPCs), 
which are then sent to an add-compare-select unit (ACSU). The computational load of the 
precomputations is reduced for multi-dimensional trellis codes by precomputing each dimension 

15 of the multi-dimensional trellis code separately. Prefiltering techniques are used to reduce the 
computational complexity by shortening the channel memory. A hybrid survivor memory 
architecture is also disclosed for a RSSE for a channel having a channel memory of length Z,, 
where the survivors corresponding to the L past decoding cycles are stored in a register exchange 
architecture (REA), and survivors corresponding to later decoding cycles are stored in a trace- 

20 back architecture (TBA) or register exchange architecture (REA). Symbols are mapped to 
information bits to reduce the word size before being moved from the first register exchange 
architecture (REA) to the trace-back architecture (TBA) or the second register exchange 
architecture (REA). 

25 
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